package com.free.chat.config;

import cn.dev33.satoken.context.SaHolder;
import cn.dev33.satoken.solon.integration.SaTokenPathInterceptor;
import cn.hutool.core.util.ArrayUtil;
import com.free.chat.entity.ApiResult;
import lombok.extern.slf4j.Slf4j;
import org.noear.solon.Solon;
import org.noear.solon.annotation.Bean;
import org.noear.solon.annotation.Configuration;

import java.util.ArrayList;
import java.util.List;

/**
 * sa-token权限配置
 *
 * @Author: 朝花不迟暮
 * @Description:
 * @Date: 2022/11/15
 */
@Configuration
@Slf4j
public class SaTokenConfig {
    // 白名单
    private static final List<String> WHITE_LIST = new ArrayList<>();

    static {
        // 登陆
        WHITE_LIST.add("/api/users/login");
        // 注册
        WHITE_LIST.add("/api/users/register");
    }

    /**
     * 注册 [sa-token全局过滤器]
     */
    @Bean
    public void tokenPathFilter() {
        Solon.app().before(new SaTokenPathInterceptor()

                // 指定 [拦截路由] 与 [放行路由]
                .addInclude("/**")
                .addExclude(ArrayUtil.toArray(WHITE_LIST, String.class))

                // 认证函数: 每次请求执行
                .setAuth(r -> {
                    // System.out.println("---------- sa全局认证");

                    // SaRouter.match("/test/test", () -> new Object());
                })

                // 异常处理函数：每次认证函数发生异常时执行此函数
                // .setError(e -> {
                //     log.error("---------- sa全局异常 ");
                //     return ApiResult.error(e.getMessage());
                // })

                // 前置函数：在每次认证函数之前执行
                .setBeforeAuth(r -> {
                    // ---------- 设置一些安全响应头 ----------
                    SaHolder.getResponse()
                            // 服务器名称
                            .setServer("sa-server")
                            // 是否可以在iframe显示视图： DENY=不可以 | SAMEORIGIN=同域下可以 | ALLOW-FROM uri=指定域名下可以
                            .setHeader("X-Frame-Options", "SAMEORIGIN")
                            // 是否启用浏览器默认XSS防护： 0=禁用 | 1=启用 | 1; mode=block 启用, 并在检查到XSS攻击时，停止渲染页面
                            .setHeader("X-Frame-Options", "1; mode=block")
                            // 禁用浏览器内容嗅探
                            .setHeader("X-Content-Type-Options", "nosniff")
                    ;
                })
        );
    }
}
